



## Experiment 2.4

Student Name: Rajiv Paul

**Branch: CSE** 

**Semester: 4th** 

Subject Name: MPI Lab

**UID:20BCS1812** 

Section/Group:607A

Date of Performance: 05/04/2022

Subject Code: 22E-20CSP-253

- 1) Aim/Overview of the practical:
- a) Shift left by 1 bit of 16bit number

Apparatus/Simulator used: 8085 simulator







#### Flowchart:







### Algorithm:

- 1. LHLD 8000H loads H-L pair with data from 8000H memory location.
- 2. MOV A,L moves register L data to A.
- 3. RAL shifts 1bit to left of accumulator.
- 4. MOV L,A moves data from A to L
- 5. MOV A,H moves data from register H to A.
- 6. RAL shifts 1bit to left of accumulator.
- 7. MOV H,A moves data from A to H
- 8. SHLD 8002H stores result at the memory location 8002H.
- 9. HLT end of the execution.





## **Steps for experiment/practical/Code:**

# BEGIN 0000H

**LHLD 8000** 

**MOV A,L** 

**RAL** 

MOV L,A

MOV A,H

**RAL** 

MOV H,A

**SHLD 8002** 

HLT

# ORG 8000H

# DB 8BH,95H





#### **Simulation:**

## 1. CODE IN EDITOR WINDOW:

```
8085 Assembly Language Editor
                 Assembler
                               Disassembler
// Name: Rajiv Paul
  UID: 20BCS1812
  Shift 16bit number left by 1 bit
# BEGIN 0000H
             LHLD 8000
             MOV A,L
             RAL
             MOV L,A
             MOV A,H
             RAL
             MOV H,A
             SHLD 8002
             HLT
# ORG 8000H
# DB 8BH,95H
```

## 2. ASSEMBLER WINDOW:

| * | Address | Label | Mnemonics | Hexco | Bytes | M-Cyc | T-States |
|---|---------|-------|-----------|-------|-------|-------|----------|
| √ | 0000    |       | LHLD 8000 | 2A    | 3     | 5     | 16       |
|   | 0001    |       |           | 00    |       |       |          |
|   | 0002    |       |           | 80    |       |       |          |
| √ | 0003    |       | MOV A,L   | 7D    | 1     | 1     | 4        |
| √ | 0004    |       | RAL       | 17    | 1     | 1     | 4        |
| √ | 0005    |       | MOV L,A   | 6F    | 1     | 1     | 4        |
| √ | 0006    |       | MOV A,H   | 7C    | 1     | 1     | 4        |
| √ | 0007    |       | RAL       | 17    | 1     | 1     | 4        |
| √ | 8000    |       | MOV H,A   | 67    | 1     | 1     | 4        |
| √ | 0009    |       | SHLD 8002 | 22    | 3     | 5     | 16       |
|   | 000A    |       |           | 02    |       |       |          |
|   | 000B    |       |           | 80    |       |       |          |
| √ | 000C    |       | HLT       | 76    | 1     | 2     | 5        |
|   |         |       |           |       |       |       |          |
|   |         |       |           |       |       |       |          |
|   |         |       |           |       |       |       |          |
|   |         |       |           |       |       |       |          |
|   |         |       |           |       |       |       |          |







#### 3. REGISTERS:







## **4.** <u>MEMORY:</u>







#### **RESULT**

#### BEFORE EXECUTION:

8000H: 8BH 8001H: 95H

#### **AFTER EXECUTION:**

8002H: 16H 8003H: 2BH





## Aim/Overview of the practical:

b) Shift left by 2 bit of 16bit number.

Apparatus/Simulator used: 8085 simulator

#### Flowchart:







## Algorithm:

- 1. LHLD 8000H loads H-L pair with data from 8000H memory location.
- 2. MOV A,L moves register L data to A.
- 3. RAL shifts 1bit to left of accumulator.
- 4. MOV L,A moves data from A to L
- 5. MOV A,H moves data from register H to A.
- 6. RAL shifts 1bit to left of accumulator.
- 7. MOV H,A moves data from A to H
- 8. MOV A,L moves register L data to A.
- 9. RAL shifts 1bit to left of accumulator.
- 10. MOV L,A moves data from A to L
- 11. MOV A,H moves data from register H to A.
- 12. RAL shifts 1bit to left of accumulator.
- 13. MOV H,A moves data from A to H
- 14. SHLD 8002H stores result at the memory location 8002H.
- 15. HLT end of the execution.





## **Steps for experiment/practical/Code:**

# BEGIN 0000H

**LHLD 8000** 

MOV A,L

**RAL** 

MOV L,A

**MOV A,H** 

**RAL** 

MOV H,A

MOV A,L

**RAL** 

**MOV L,A** 

**MOV A,H** 

**RAL** 

MOV H,A

**SHLD 8002** 

HLT

# ORG 8000H

# DB 8BH,95H





#### **Simulation:**

## 1. CODE IN EDITOR WINDOW:

```
8085 Assembly Language Editor
                Assembler
                              Disassembler
// Name: Rajiv Paul
// UID: 20BCS1812
// Shift 16bit number left by 2 bit
# BEGIN 0000H
            LHLD 8000
            MOV A,L
            RAL
            MOV L,A
            MOV A,H
            RAL
            MOV H,A
            MOV A,L
            RAL
            MOV L,A
            MOV A,H
            RAL
            MOV H,A
            SHLD 8002
            HLT
# ORG 8000H
# DB 8BH,95H
```





## **2.** ASSEMBLER WINDOW:

|   | 000     |       | Ass       | sembler |       |       |          |
|---|---------|-------|-----------|---------|-------|-------|----------|
| * | Address | Label | Mnemonics | Hexco   | Bytes | M-Cyc | T-States |
| √ | 0000    |       | LHLD 8000 | 2A      | 3     | 5     | 16       |
|   | 0001    |       |           | 00      |       |       |          |
|   | 0002    |       |           | 80      |       |       |          |
| √ | 0003    |       | MOV A,L   | 7D      | 1     | 1     | 4        |
| √ | 0004    |       | RAL       | 17      | 1     | 1     | 4        |
| √ | 0005    |       | MOV L,A   | 6F      | 1     | 1     | 4        |
| √ | 0006    |       | MOV A,H   | 7C      | 1     | 1     | 4        |
| √ | 0007    |       | RAL       | 17      | 1     | 1     | 4        |
| √ | 8000    |       | MOV H,A   | 67      | 1     | 1     | 4        |
| √ | 0009    |       | MOV A,L   | 7D      | 1     | 1     | 4        |
| √ | 000A    |       | RAL       | 17      | 1     | 1     | 4        |
| √ | 000B    |       | MOV L,A   | 6F      | 1     | 1     | 4        |
| √ | 000C    |       | MOV A,H   | 7C      | 1     | 1     | 4        |
| √ | 000D    |       | RAL       | 17      | 1     | 1     | 4        |
| √ | 000E    |       | MOV H,A   | 67      | 1     | 1     | 4        |
| √ | 000F    |       | SHLD 8002 | 22      | 3     | 5     | 16       |
|   | 0010    |       |           | 02      |       |       |          |
|   | 0011    |       |           | 80      |       |       |          |
| √ | 0012    |       | HLT       | 76      | 1     | 2     | 5        |





## **3.** REGISTERS:

|                                                                    |                                                                    |                                      | R                          | egist     | ers | :                               |                |                                       |                                  |   |     |          |
|--------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------|----------------------------|-----------|-----|---------------------------------|----------------|---------------------------------------|----------------------------------|---|-----|----------|
| Registe                                                            | er                                                                 | Va                                   | lue                        | 7         | 7 ( | 6                               | 5              | 4                                     | 3                                | 2 | 1   | 0        |
| Accumu                                                             | lator                                                              |                                      | 56                         |           | 0   | 1                               | 0              | 1                                     | 0                                | 1 | 1   | 0        |
| Registe                                                            | r B                                                                |                                      | 00                         |           | 0   | 0                               | 0              | 0                                     | 0                                | 0 | 0   | 0        |
| Register C<br>Register D<br>Register E<br>Register H<br>Register L |                                                                    |                                      | 00<br>00<br>00<br>56<br>2D |           | 0   | 0 0<br>0 0<br>0 0<br>1 0<br>0 1 | 0              | 0                                     | 0                                | 0 | 0   | 0        |
|                                                                    |                                                                    |                                      |                            |           | 0 0 |                                 | 0              | 0                                     | 0                                | 0 | 0   |          |
|                                                                    |                                                                    |                                      |                            |           |     |                                 | 0              | 0                                     | 0                                | 0 | 0   | 0        |
|                                                                    |                                                                    |                                      |                            |           |     |                                 | 1<br>0         | 0<br>1                                | 1                                | 1 | 0   |          |
|                                                                    |                                                                    |                                      |                            |           |     |                                 |                |                                       | 1                                | 0 | 1   |          |
| Memory                                                             | r(M)                                                               |                                      | 00                         |           | 0   | 0                               | 0              | 0                                     | 0                                | 0 | 0   | 0        |
|                                                                    |                                                                    |                                      |                            |           |     |                                 |                |                                       |                                  |   |     |          |
| Resister                                                           |                                                                    | Va                                   | lue                        | 5         |     | Z                               | *              | AC                                    |                                  | Р | *   | CY       |
| Flag Res                                                           | sister                                                             |                                      | 00                         |           | 0   | 0                               | 0              | 0                                     | 0                                | 0 | 0   | 0        |
|                                                                    | ointer(SP<br>Pointer (                                             | •                                    |                            |           |     |                                 |                |                                       | 000<br>62D                       |   |     |          |
| Memory<br>Progran<br>Progran<br>Clock Cy                           | •                                                                  | (HL)<br>Word(P<br>(PC)<br>ter        | SW)                        |           |     |                                 |                | 5 0                                   |                                  | ) |     |          |
| Memory<br>Progran<br>Progran<br>Clock Cy<br>Instruct               | Pointer ( n Status V n Counter yele Count tion Coun                | (HL)<br>Word(P<br>(PC)<br>ter<br>ter |                            | TDAD      |     |                                 |                | 5<br>5<br>0<br>9                      | 662D<br>6600<br>0012<br>00       | ) | 105 |          |
| Memory<br>Program<br>Program<br>Clock Cy<br>Instruct               | r Pointer (<br>n Status V<br>n Counter<br>ycle Count<br>tion Count | (HL)<br>Word(P<br>(PC)<br>ter<br>ter |                            | TRAP      |     | R7                              | <b>'</b> .5    | 5<br>5<br>0<br>9                      | 662D<br>6600<br>0012<br>00<br>16 | ! | R5  | -        |
| Memory<br>Progran<br>Progran<br>Clock Cy<br>Instruct               | Pointer ( n Status V n Counter yele Count tion Coun                | (HL)<br>Word(P<br>(PC)<br>ter<br>ter |                            | TRAP<br>0 |     | R7                              | 7.5<br>0       | 5<br>5<br>0<br>9                      | 662D<br>6600<br>0012<br>00       | ! | R5  | .5       |
| Memory<br>Program<br>Program<br>Clock Cy<br>Instruct               | r Pointer (<br>n Status V<br>n Counter<br>ycle Count<br>tion Count | (HL) Word(PC) ter ter                |                            |           |     |                                 | 0              | 5<br>5<br>0<br>9                      | 662D<br>6600<br>0012<br>00<br>16 |   | R5  | -        |
| Memory<br>Program<br>Program<br>Clock Cy<br>Instruct               | Pointer ( n Status V n Counter ycle Count tion Count   SID         | (HL) Word(PC) ter ter                |                            | 0         |     |                                 | 0              | 5<br>5<br>0<br>9<br>1                 | 662D<br>6600<br>0012<br>00<br>.6 |   |     | 0        |
| Memory Program Program Clock Cy Instruct SOD 0                     | Pointer ( n Status V n Counter ycle Count tion Count   SID         | (HL) Word(PC) ter ter                | SOD                        | SDE       | *   |                                 | <b>0</b><br>R7 | 5<br>C<br>G<br>G<br>1                 | 662D<br>6600<br>0012<br>00<br>.6 | 1 | И   | <b>0</b> |
| Memory Progran Progran Clock Cy Instruct SOD 0                     | Pointer ( n Status V n Counter ycle Count tion Count   SID         | (HL) Word(P (PC) ter ter INTR        | SOD                        | O SDE     | *   |                                 | <b>0</b><br>R7 | 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 | 662D<br>6600<br>0012<br>00<br>.6 | 1 | И   | <b>0</b> |





## **4.** <u>MEMORY:</u>

|                |      | Mem    | ory Edito | r        |  |
|----------------|------|--------|-----------|----------|--|
| Memory Range:  | 000  |        | FFFF      |          |  |
| Memory Address |      |        | Value     |          |  |
| 0009           |      |        |           | 7D       |  |
| A000           |      |        |           | 17       |  |
| 000B           |      |        |           | 6F       |  |
| 000C           |      |        |           | 7C       |  |
| 000D           |      |        |           | 17       |  |
| 000E           |      |        |           | 67       |  |
| 000F           |      |        |           | 22       |  |
| 0010           |      |        |           | 02       |  |
| 0011<br>0012   |      |        |           | 80<br>76 |  |
| 8000           |      |        |           | 76<br>8B |  |
| 8001           |      |        |           | 95       |  |
| 8002           |      |        |           | 2D       |  |
| 8003           |      |        |           | 56       |  |
| 5555           |      |        |           | - 50     |  |
|                |      |        |           |          |  |
|                |      |        |           |          |  |
|                |      |        |           |          |  |
|                |      |        |           |          |  |
| Show entire    | memo | ny con | tont      |          |  |





#### **RESULT**

**BEFORE EXECUTION:** 

8000H: 8BH 8001H: 95H

#### **AFTER EXECUTION:**

8002H: 2DH 8003H: 56H





## Learning outcomes (What I have learnt):

- 1.Learnt about 8085 simulator
- 2. Learnt how to shift left by 1bit and 2bit of 16bit number.
- 3. Learnt about RAL and its function.
- 4.
- **5.**





# Evaluation Grid (To be created as per the SOP and Assessment guidelines by the faculty):

| Sr. No. | Parameters | Marks Obtained | Maximum Marks |
|---------|------------|----------------|---------------|
| 1.      |            |                |               |
| 2.      |            |                |               |
| 3.      |            |                |               |
|         |            |                |               |